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(54) Tifle: A BlOMEmiC BASED METHOD FOR SOFTWARE DISTRIBUTION 
(57) Abstract 



A method is provided for protecting distributed software, cither 
through the internet/telephone networks or via physical storage media 
like floppy diskettes, magnetic tapes, CD-ROMS, DVD-ROMS, etc., 
by using biometric information (personal fingerprint information in 
particular). In one approach, the fingerprint of the software purchaser 
is embedded into the purchased software at the time of purchase. 
All subsequent use of the software by the purchaser at his/her home 
or office is subject to (a) providing his/her fingerprint again and (b) 
the fingerprint matches that embedded in the purchased software. In 
another related approach, prior to the use or installation of distributed 
software, the user's computer calls a central management server station. 
Hie software then requests the user to provide his or her fingerprint 
by any device that would capture such information. The fingerprint 
information is then processed on the local user computer by any image 
processing program, and the relevant information is then sent to the 
centra] server along with a key or serial number that is built into die 
distributed software. The central management server then compares 
the provided information with the infomriation previously stored in its 
central database and decides whether the user is authorized. Such a 
method can also be employed in a licence management system whereby 
software product usage can be remotely monitored and fees for usage 
charged appropriately. 
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A Bionietric Based Method for Software Distribution 



Cross Reference to Related Applications 

5 This application claims priority from (1) US Provisional Patent 

Application No. 60/025,913 filed September 11, 1996, entitled 
BIOMETRIC BASED METHOD FOR SOFTWARE DISTRIBUTION 
and naming Y. Li, D. R, K. Rao, and S. Subbiah as inventors, and (2) 
US Provisional Patent Application No. 60/025,949, filed September 11, 

10 1996, entitled EMBEDDABLE MODULE FOR FINGERPRINT 
CAPTURE AND MATCHING, and naming R. Rao, S. Subbiah, Y. Li, 
and D. Chu as inventors. Both of these applications are incorporated 
herein by reference in their entireties and for all purposes. 



15 Background of the Invention 

Software piracy has been and will always be a major enemy in the 
software industry. Billions of dollars in revenue are lost each year due 
to unauthorized copying and distribution of pirated software (see May 
20, 1996 of the Wall Street Journal). Due to the lack of efltctive 

20 metliods in the losing battle against software piracy, the software 
industry can only hope that for every ten copies of software disuibuted 
only one copy is purchased legitimately. This lost revenue to the 
software industiy is reflected by the higher prices of software in the 
market; both legitimate software buyers and companies that sell the 

25 software are the vicdms. 

The various methods that software companies currently use to 
protect their products from unauthorized copying work to some extent 
in preventing individual users from making a small number of copies 
for friends/reladve etc. Nevertheless, tliese methods have been largely 

30 ineffective against the large organized piracies in Europe and Asia. It 
has been argued, and to some degree legitimately, tliat the former type 
of software copying — individual consumers giving friends and relatives 
copies - is actually a healthy contribution to tlie software industry as 
this amounts to a free form of advertising. Particularly with the now- 

35 standaid so-called "guilt banners" that loudly proclaim the original 
buyer's name, it is believed that sooner or later these friends/relatives 
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will value Ihc product enough to buy their own original copies. 
However, this perceived boon is not at all tiue of the completely 
destructive effects of the latter type of large scale organized piracy. 

As well known in tlie state of the art some of tliese partly 
5 effective cxistUig methods include (a) locking out simple copying 
commands Irom most opcradng systems to prevent direct copying of the 
disk containing the software (which can be readily bypassed with more 
sophisdcated copying software); (b) software only offered on a CD- 
ROM which can then periodically check for the presence of the original 
10 purchased CD during the running of the program (however, with the 
availability of low-cost recordable CD-ROM drives, this no longer 
suffices); and (c) a password system which requires the user to type a 
password that is provided in the original users' manual in the form of a 
serial number or key word during the running of the program or the 
15 initial installation of the program (however, such passwords can be 
readily copied and distributed along with the pirated software 
themselves; they can also be forgotten). 

Given the difficulties of these marginally effective methods, a 
preferred approach would be for the authorized user to give or be given 

20 a "key", which cannot be duplicated, to each copy of the software such 
that tJie software will only run or be installed when tlie correct "key" is 
present. This method requires that the "key" cannot be duplicated and 
distributed. Advanced methods along these lines have been recendy 
described; see for example, U.S. Pat. No. 5,337,357 (Chou et al.) and 

25 U.S. Pat. No. 5,260,999 (Wyman), both of which are incorporated 
herein by reference for all purposes. In particular, the method for 
protecting distributed software by Chou et al. relies on a unique factor 
such as an accessible serial number or the generation of a profile of the 
computer of the user which is entered individually and/or with a 

30 random factor to generate a unique first key which will differ for 
different computers. The first key is sent to a processing center which 
then generates a second key. The user applies tlie second key which 
compares the unique and/or random factors. If the comparison 
matches, the first and second keys are used in an algorithm in the 

35 software to generate a decrypting key permitting tlie customer to 
purchase the selected program(s). 
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While this technique provides some improvement over traditional 
piracy avoidance techniques, it suffers from certain difficulties. For 
example, a user cannot easily move his/her copy of tiie software from 
one machine to another or install the software on multiple machines in 
5 his/her possession. As is understood in the art, such usage is often 
legitimate. 

What is needed therefore is an improved method for 
authenticating operation of software tliat does not rely on the profile of 
a particular machine. 

to 

Summary of the Invention 

The present invention protects software from unauthorized 
distribution. It accomplishes this by employing biometric information, 
particularly the personal fingerprint information that is unique to every 

15 individual, to generate the user-specific "key" rather than the serial 
number of the computer, phone number of the computer, etc. This then 
ensures that the purchased/distributed software can only be operated by 
the person/persons who purchased it By this invention, each copy of 
the software is uniquely assigned to one user, and the software is 

20 authorized for use only in the presence of the user. 

One aspect of the invention provides a method (which may be 
provided as a sequence of steps stored on a computer readable medium) 
for controlling installation of a software program. This method may be 
characterized as including the following: (a) providing (i) fingerprint 

25 data from a user and (ii) a separate identifier of tlie software program 
(e.g., a serial number); (b) determining whether the fingerprint data 
provided allows installation of the software program; and (c) if tlie 
fingerprint data is not ibund to allow installation, blocking installation. 
Preferably, this method is implemented for purchase of software over 

30 the Internet. 

In one embodiment, step (a) involves transmitting the user's 
fingerprint data and a serial number of the software program from a 
local computer of the user to a remote authentication system controlled 
by an enterprise responsible for distribution of the software program. 
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The authentication system may then transmit instructions to block to tlie 
local computer. 

As an exti'a check on the installation, the system may also 
determine whether the number of installations exceeds a pre-set 
5 maximum. Installation is then blocked if the number of installations is 
found to exceed the pre-set maximum. 

Anotlier aspect of the invention provides a method for controlling 
use of a software program. This mediod may be characterized as 
including the following: (a) accepting fingerprint data from a user of 

10 the software program; (b) comparing the user's fingerprint data with 
stored fingerprint data provided for the software program; and (c) if 
the user's fingerprint data does not match the stored fingerprint data, 
blocking execution of the software program. In some embodiments, the 
method will begin with the system prompting the user to provide die 

15 fingerprint data prior to continued execution of the software program. 

Preferably, the stored fingerprint data was obtained from a 
purchaser of the software program contemporaneous with a purchase of 
the software program. The purchaser is then an authorized user of the 
software. In some embodiments, the purchaser may give use 
20 authorization to a limited number of otlier people. In such cases, the 
system must store fingerprint data for a plurality of users of die 
software program. 

Yet another aspect of the invendon provides a method for 
controlling use of a software program on a pay-per-use basis. This 

25 meUiod may be characterized as including the following: (a) accepdng 
fingerprint data from a user of the software program; (b) determining 
whether the user's fingerprint data allows access to die software 
program; and (c) if the user's fingerprint data is found to allow access 
to the software program, monitoring a quantity of use of the software 

30 by die user so that the user can be charged for the quantity of use. In 
one embodiment, a length of time during which the software program is 
operated comprises tlie quantity of use. 

It should be understood diat the present invention also relates to 
machine readable media on which are stored software produced in 
35 accordance with the requirements of this invention, or program 
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instructions for performing metiiods of this invention. Such media 
include, by way of example, magnetic disks, magnetic tape, optically 
readable media such as CD ROMs, semiconductor memory such as 
PCMCIA cards, etc. In each case, the medium may take die form of a 
5 portable item such as a small disk, diskette, cassette, etc., or it may talce 
the form of a relatively larger or immobile item such as a hard disk 
drive or RAM provided in a computer. Furthermore, program 
instructions implementing this invention may sometimes be transported 
over a communications network. 

0 These and other features and advantages of tlie invention will be 

described in detail below with reference to the associated figures. 



Brief Description of the Drawings 

FIG. 1. is an illustration of an apparatus/device that may be 
15 employed to register a copy of a software program with a user's 
fingerprint. 

FIG. 2 is a process flow diagram depicting steps employed in a 
first metliod for authenticating operation of a software program in 
accordance with a preferred embodiment of this invention. 

20 FIG. 3. is an illustration of a device/apparatus for fingerprint 

authentication in accordance with a second preferred embodiment of the 
present invention. 

FIG. 4. is a depiction of a list of fingerprints retained by an 
enterprise for the purpose of authenticating each new installation of a 
25 software program in accordance with the second preferred embodiment 
of this invention. 

FIG. 5 is a process flow diagram depicting steps employed in the 
second preferred embodiment for authendcating operation of a software 
program. 

30 FIG. 6 is a flow diagram depicting a fingerprint matching 

technique that may be employed with the present invention. 
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Del ailed Description of the Preferred Embodiments 

For purposes of this discussion, the term "computer" will 
genericaily refer to all computing devices, including personal 
computers, network computers, bridges, routers, work stations, 
5 supercomputers, embedded computer processor chips, etc. 

Bioiiietric information includes many different types of personal 
information including, for example, a user's voice, personal 
information, photograph, hand shape, retina, palmprint, and 
fingerprint. Although, any of these can be used with tliis invention, 

10 fingerprints are preferred for various reasons. First of all, the 
biometric information must be unique and theoretically no two persons 
should have the same information. Secondly the "key" has to be easily 
remembered by the user and yet not easily duplicated by others. 
Thirdly, the search time has to be instantaneous. Finally, the device that 

15 scans the biometric information has to be user-friendly and easy to use. 
Fingerprint technology meets all these requirements simultaneously. 

Fingerprint technology including hiudware image capture, 
software image processing, software/hardware for fingerprint data 
storage and software for fingerprint analysis/comparison is a relatively 

20 mature technology with over 20 years of development (see, for 
example, U.S. Pat. Nos. 2 952 181, 4 151 512, 4 322 163, 4 537 484, 4 
747 147, 5 467 403, each of which is incorporated herein by reference 
for all purposes). The term "fingerprint" as used herein refers to 
handprints, palmprinLs, and other unique skin patterns in addition to 

25 traditional fingerprints. 

The present invention may employ sophisticated hardware and 
software to allow rapid fingerprint based identification as described in 
U.S. Provisional Application No. 60/025,949, filed on September 11, 
1996, naming R. Rao, S. Subbiah, Y. Li & D. Chu as inventors, and 

30 previously incorporated by reference. That application describes an 
extremely small, low-cost fingerprint capture hardware module that 
lends itself to ready insertion into many devices. The referenced 
Provisional Application was incorporated herein by reference for all 
purposes and is illustrative of die maturity of tlie fingerprint capture 

35 and comparison technology. 
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In general, the present invention provides techniques which rely 
on comparison of stored fingerprint data v/lth a user's fingerprint data 
taken at the time of installation or operation of a softv^are program. 
Such methods may be employed for the purpose of conU'oliing softv^are 
5 distribution. Various methodologies employing such comparison may 
be used wiUi this invention. For purposes of illustration, two such 
methods arc described below. 



1 . Method Employing Fingerprints Before Each Operation 

10 This method will be described with reference to FIGs. 1 and 2. It 

requires that bodi the buyer of the software and the store where the 
software is sold have a fingerprint capturing device attached to a 
computer on which the software would be run. Such fingerprint 
capturing devices can be of any kind and liom any of a number of 

15 manufacturers (e.g. from Identix of Sunnyvale, California; Digital 
Biometrics of Minncntonka, MN; Printrack of Los Angeles; Morpho of 
France). In a preferred embodiment, a specially modified computer 
mouse or standard computer peripheral, like a keyboard or pointing 
device, as described in U.S. Provisional Application No. 60/025,949, 

20 previously incorporated by reference, can be used to capture the 
fingerprints at very low-cost. 

As depicted in FIG. 1, the fingerprint information is captured by 
any of these means at the software store where the user purchases the 
software. At the time of the purchase, the particular copy of a software 
25 program 104 being purchased is put into a disk drive or some other 
storage media of a computer 103 that has a fingerprint capturing device 
101 attached to it directly, or through a network. A generic data 
connection 105 connects computer 103 with fingerprint capture device 
101. 

30 A preferred sequence of operation 200 will now be described 

with rci'erence to the flow chart of FIG. 2. The process begins at 20 J, 
and in a step 203 the buyer tlien inserts tlie finger(s) 102 of his/her 
choice into the capturing device 101. The captured fingerprint 
information is then processed by converting to a digital representation 

35 (e.g., a collection of minutiae) at a step 205 and subsequently written 
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and altaclicd (e.g., embedded in the executable version of tlie distributed 
code in a suitably encrypted manner) to the copy of the software being 
purchased 104 at a step 207. 

After leaving the store, the user will attempt to install and/or 
5 operate the purchased software program at a step 209. At that time, the 
program asks the user to put the finger(s) 102 on the buyer's 
fingerprint capturing device at a step 211. Next, at a step 213, the 
program compares the recently captured fingerprint data with the 
stored fingerprint data embedded in the program when the software was 
10 purchased. The program can then determine wiiether the two sets of 
fingerprint data match at a decision step 215. Assuming that the 
program finds that the fingerprint data does not match, it denies access 
to the software at a step 217. Tiie process then concludes at 221. If on 
the other hand, the program finds that tiie new and stored fingerprints 
15 do match (i.e., decision step 215 is answered in the affirmative), access 
to the software is allowed at a step 219. The process then concludes at 
221. 

Only when the fingerprint information matches that encoded widi 
the purchased software does the installation of tlie software occur. Tiiis 
20 method ensures that only the original buyer of the software is 
authorized to both first install and then at all subsequent times use tlie 
software. 

Such a process could be reversed if the buyer desires to return the 
product to the store. Upon return of the software the buyer's 
25 fingerprint information is again captured in the store. If this captured 
fingerprint information matches the fingerprint information encoded 
with the software, the buyer's fingerprint is erased from the software 
allowing it to be purchased again by another buyer. 

In a modification of the method, the single buyer of the software 
30 can be permitted to authorize his/her friends/relatives to use it for 
limited periods of time. For instance, the buyer can allow a few Hmited 
users to add their fingerprint to the software at any time. These 
temporary secondary users can use the product or copy of the product 
on other computers for a while. Under such conditions, the purchased 
35 software will either upon a fixed time (a few weeks) or a fixed number 
of user sessions disable itself and not allow these secondary users to 
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continue using the program. Continued use will require these secondary 
users to approach the original buyer and have him/her re-validate tlie 
software for another fixed period of time or a fixed number of sessions. 
This modification allows the continuation of the legitimate perception 
5 that allowing temporary access to tlie original buyer's friends and 
families amounts to free advertisement of the software, with the 
expectation that these secondary users will ultimately buy their own 
copy to avoid the nuisance, inconvenience, and embarrassment of 
repeatedly approaching the original buyer to re-validate their 
10 increasingly illegal use. 

While this metliod represents a significant advance, it may in 
theory be susceptible to a "generic" or a fake fingerprint being given at 
the time of purchase. Then, the software could be copied en masse and 
distributed with multiple copies of this "generic" or foke fingerprint. 

15 For example, such a generic fingerprint could come from a plastic 
molded finger with foke but realistically detailed fingerprint lines/ridges 
etched onto it. A particularly gruesome source for a generic fingerprint 
could be from a suitable embalming of a finger from a dead person. 
While it is true that specialized fingerprint capture hardware (e.g., 

20 hardware available from Identix Corporation of Sunnyvale, CA) can 
differentiate the presence of a "warm living finger" from a "dead 
finger" or a "I^ike copy," the second method described in the next 
section avoids this potential problem all together. 



25 2. Method Employing Fingerprints Before Each Installation 

This method will be described with reference to FIGs. 3-5. It 
only requires the buyer, and not the store, to have a fingerprint 
capturing device. As illustrated, the buyer purchases software 304 from 
a store. Each copy of the software has a unique serial number 
30 embedded in it by the software manufacturer 401 (Fig. 4). 

A preferred software installation/authentication process 500 is 
represented in Figure 5 and begins at 501. At the buyer's home or 
office 301, the buyer begins tlie first-time installation of software 
program 304 (step 503). The software dien asks the user to provide the 
35 fingerprint information through an attached fingerprint capturing 
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device 303 (step 505). Again, sucli a fingerprint capture device 303 can 
be any of kind and from any manufacturer. 

Next, as shown in Figure 3, tiie purchased software 304 connects 
(step 507) via a modem/network 306 to the software manufacturer's 
5 central database system 307 and provides both the serial number 401 of 
the software and the user's fingerprint 302 (step 509). Unique serial 
numbers arc embedded by the manul'acturer in each copy of die 
software prior to purchase. 

FIG. 4. represents a database or tabular list where every buyer's 
10 fingerprint 402 is stored. Each fingerprint 402 is permanendy 
associated with the particular embedded serial number or other forms 
of ID of the copy of the software that he/she is installing for the first 
time after purchase. This list is kept in the server computer at the store 
or the software manufacturer's central database computer. 

15 Returning to FIG. 5, at a step 511, the central system then 

searches its database (Fig. 4) for the serial number 401. At a decision 
step 513, the system determines whether die serial number has been 
registered before. If the serial number 401 is indeed being registered 
for the first time, die presented fingerprint information 402 is stored in 

20 the database and permanently associated with the serial number (step 
515). A user authorization code is then sent back to die user's computer 
to authorize the use of the purchased software (step 517). Thereafter, 
installation of the software is allowed to proceed at the buyer's local 
computer 305 (step 519) and this process is concluded at 529. 

25 If the system determines that the serial number it has received 

already has an associated fingerprint 402 in its database (decision step 
513), it compares the newly provided fingerprint information with the 
existing stored one to determine if they match (decision step 521). If 
they do not match, the main system sends a signal back to the local 

30 program on die user's computer to signal the failure of authentication 
(step 525). Tliis then blocks the installation of the software on the local 
system (step 527) and the process is concluded at 529. 

If the two prints match (as determined at decision step 521), then 
the central system determines whedier a pre-set maximum number of 
35 installations has been exceeded (decision step 523). The system may 
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allow more than one installation but only up to a certain number of 
times that has been pre-set by tlie manufacturer (N.B. to allow the user 
to legally install on several of his or her computers). If this pre-set 
limit on the number of separate installations is exceeded (as determined 

5 by the central system at decision step 523), a special request from the 
user is required to allow proper installation of tlie software. Again, as 
detailed under method 1, this second method can also be modified so 
that the original primary buyer can allow his/her friends/relatives to 
become secondary users with temporary limited access to the software. 

10 As before, such use would involve the secondary users being re- 
validated to use the software by providing their fingerprints to the 
software in the presence of the primary user. 

If the central system determines at step 523 that die number of 
installations did not exceed the pre-set maximum (or if it did it was 

15 done with special authorization), process control is directed to step 517, 
where the system sends a user autliorization code as described above. If 
on the other hand, the central system determines that the number of 
installations exceeded the pre-set maximum without special 
authorization, then process control is directed to step 525, where a 

20 failure to authenticate signal is sent to the local computer. 

With this , second method, the potential drawback of tlie first 
method - the possible use of a generic or fake finger for initial 
registration at purchase and subsequent en masse illegal authorization of 
many copies of software - can be readily rectified. When a generic or 

25 fake finger is first used to authorize the use of the purchased copy of the 
software, the central server computer will allow such use and 
permanently associate the details of this generic fingerprint with the 
purchased copy's unique serial number. When it is used subsequently to 
install additional copies of tlie software the server will allow usage up to 

30 the pre-set limit of multiple installations that the buyer was allowed at 
the time of purchase. When this number is exceeded, as would be the 
case with illegal en masse piracy, the central server computer will block 
further attempts to install more copies of tlie software using diis generic 
fingerprint. 

35 These two mediods can be used separately or in combination with 

one another. They will curtail the illegal piracy that has cost the 

1) 
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software industry and consumers billions of dollars. A modified 
version of the second method could also be used to purchase software 
through the internet where after providing fingerprint 302 dirough tlie 
internet 306 to manui^cturer 307, a copy of tlie software to be 
5 purchased encoded with serial number 401 and user's fingerprint 402 is 
downloaded or sent to user's computer 305 via network 306. The 
further distribution or installation of the software can be monitored as 
described in the second method. The only difference being that tlie 
software given to user is provided through a different media. 

10 

3. Fingerprint Capture and Matching Methods 

Suitable design parameters of fingerprint capture devices 101 
(FIG. 1) and 303 (FIG. 3) can be specified based upon the general 
requirements of fingerprint analysis and matching algorithms. A 

15 typical human fingerprint has an aspect ratio of about three to two; that 
is, it is one-half times as long as it is wide. The average fingerprint has 
about 50 ridgelincs separated by intervening valley lines that are about 
equally as thick. Generally the lines run from left to right and as tliey 
do they first traverse upwards and later downwards. Given Uiis amount 

20 of information, the Federal Bureau of Investigation CTBI") has 
suggested that fingerprint detection systems should provide an array of 
512x512 pixels since it allows for at least four pixels per ridgeline and 
four per valley line. Preferably, though not necessarily, imagers 
employed in the fingerprint capture devices 101 and 303 contains an 

25 array of at least 512x512 pixels. Using sophisticated fingerprint 
imaging algorithms such as those described in the above-referenced US 
Provisional Application 607/025,949, significandy smaller airays can be 
employed. In one embodiment, the array may include 120x160 pixels 
and in another embodiment may include 240x160 pixels. The use of 

30 such small arrays has the advantage of requiring (1) less processing 
resources from the local computer's CPU and (2) faster transmission of 
fingerprint data over serial ports such as those employed widi computer 
mice. 

Accurate fingerprint matching technology, which is well-known 
35 in the art (see, for example, U.S. Pat. No. 2 952 181, 4 151 512, 4 322 
163, 4 537 484, 4 747 147, 5 467 403 which were previously 
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incorporated by reference), has for over a hundred years relied on the 
extraction and subsequent comparison of specialized features called 
minutiae. Minutiae are essentially of two equally frequent types - either 
the abrupt ending of a line in the middle of the fingerprint or the fusion 
5 of two lines to create a Y-shaped junction. Typically there are about 60 
or 70 such features in a fingerprint and it is the relative location of 
these from each other that creates a unique spatial pattern that 
statistically no other human can possess. 

Suitable methods of fingerprint matching may involve software 

10 processing steps as illustrated in FIG. 6. After capturing the fingerprint 
image (step 601), assuming the FBI-standard 512x512 pixel array, a 
contrasting algorithm (step 603) reduces all the gray shades of a 
captured image 602 to either black (for ridgelines) or white (for valley 
lines) as shown in image 604. Traditionally these algorithms are omni- 

15 directional. Basically, the particular shade of gray at each pixel is 
compared with those of the neighboring pixels in all directions and if 
judged to be relatively darker than most of its neighbors it is deemed to 
be black, otherwise white. After this contrasting step, the contrasted 
image 604 is further processed by a thinning algoritlim (step 605). The 

20 object here is to reduce the black lines from being on average four 
pixels thick to only one pixel thick, thereby increasing the number of 
white pixels substantially. A thinned image 606 is then examined by 
furtiier algorithms (step 607) that attempt to deduce and accurately 
extract the minutiae and their locations as shown in a map 608. The 

25 process is then completed at 609. All further fingerprint 
matching/comparison relies only on these 60 or 70 extracted pieces of 
information. 

After the minutiae have been extracted, they must be matched 
against the stored fingerprints. This requires matching the two- 
30 dimensional coordinates of the stored and recently captured 
fingerprints. If the coordinates match to within a defined tolerance, the 
tokens are deemed a match. 

As known in the state of the art, many fingerprint matching 
schemes involve the generation of inter-minutiae-based keys (i.e., 
35 distance vectors, etc.) that while being generally similar, will vary 
between multiple impressions of die same finger. Various inter- 
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minutiae distance- vector-derived formats are known in the art. Many 
of these (as well as variations on them) may be suitable for use with tliis 
invention. 

Suitable matching schemes are described in, for example, US 
5 Patent No. 4,747,147 issued to Sparrow on May 24, 1988, US Patent 
No. 5,493,621 issued to Matsumura on February 20, 1996, and 
information provided at the World Wide Web site 
www.Lucent.Com/Press/0597/minul. GAP. Each of these documents is 
incorporated herein by reference for all purposes. A typical description 
10 of a processed fingerprint is a list of x, y and angle tabulation of each 
minutia. Minor modification to these linear values (e.g., adding slight 
random displacements) will still reflect the same underlying fingerprint, 
allowing for variation during multiple impressions (e.g., slight 
distortions and rolling during the pressing of the finger). 

15 

4. Other Embodiments 

Another potential use of the above-described systems is that they 
give software manufacturers the option of charging their clients by 
usage — either by usage time or number of users. That is, the concept 
20 of pay-per-use. If the original user or buyer is given the option of 
adding additional users by the program, then the program can keep 
track of the number of users and the amount of elapsed time at each use. 
Such information can be sent back to the manufacturer periodically, 
either by postal mail for the first method or electronic mail for the 
second method, for billing purposes. 

While this invention has been described in terms of a few 
preferred embodiments, it should not be limited to the specifics 
presented above. For example, while the system of this invention has 
been described as protecting a conventional software program, the 
invention may be employed to protect portions of a larger software 
suite by preventing unauthorized access to certain subroutines, modules, 
database viev^s, etc. Many similar variations on the above-described 
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preferred embodiment, may be employed. Therefore, the invention 
should be broadly interpreted with reference to the following claims. 
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CLAIMS 

What is claimed is: 

1. A method for controlling installation of a software program, 

5 the metliod comprising: 

(a) providing (i) fingei-print data from a user and (ii) a 
separate identifier of the software progi-am; 

(b) determining whether the fingerprint data provided 
allows installation of the software program; and 

10 (c) if the fingerprint data is not found to allow installation, 

blocking installation of the software program. 

2. The method of claim i , wherein (a) comprises transmitting the 
user's fingerprint data and a serial number of the software program 

15 from a .local computer of the user to a remote audientication system 
controlled by an enterprise responsible for distribution of die software 
program. 

3. The mediod of claim 1, wherein determining whether the 
20 fingerprint data provided allows installation of tlie software program 

comprises: 

determining whether any fingerprint data has been 
previously provided for the software program; and 

if not, storing the fingerprint data in association with the 
25 separate identifier lx»r the software program, such diat in subsequent 
installations of the software program, newly presented fingerprint data 
is matched against the stored fingerprint data. 

4. The method of claim 1, wherein determining whether the 
30 fingerprint data provided allows installation of the software program 

comprises: 

matching the provided fingerprint data with stored 
fingerprint data provided in association with the separate identifier, 

such that if the provided fingerprint data does not match 
35 the stored fingerprint data, providing instructions to block installation. 

5. The method of claim I, wherein blocking installation 
comprises transmitting instructions to block to a local computer of the 
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user from a remote authentication system controlled by an enterprise 
responsible for distribution of the software program. 

6. The metliod of claim 1, wherein determining whether the 
5 fingerprint data provided allows installation of the software program 

comprises: 

determining whether the number of installations exceeds a 

pre-set maximum, 

such that installation is blocked if the number of 

10 installations is found to exceed tlie pre-set maximum. 

7. The method of claim 1, wherein the software program is 
purchased over the internet. 

15 8. A computer readable medium including instructions for 

operating a computer system to control installation of a software 
program, the instructions comprising: 

receiving a signal to install said software program; 
accepting a user's fingerprint data; and 
20 blocking installation of said software program if the 

fingeiprint data is not found to allow installation of said software. 

9. A computer readable medium as in claim 8, further 
comprising the following instruction: 

25 transmitting said user's fingerprint data from the user's 

local computer to a remote autlicntication system controlled by an 
enterprise responsible for distribution of the software program. 

10. A computer readable medium as in claim 8, further 
30 comprising instructions for converting an image of said user's 

fingerprint to said fingerprint data. 

11. A computer readable medium including instructions for 
operating a computer system to control installation of a software 

35 program, the instructions comprising: 

receiving a user's fingerprint data from a local computer 
where the user is attempting to install the software program; 
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determining if the user's fingerprint allows installation of 

software program; and 

if the user's fingerprint is not found to allow installation of 
the software program, blocking installation of said software program. 

5 

12. A computer readable medium as recited in claim 11, further 
comprising the following instructions: 

receiving an identifier of a copy of the software program 

to be installed; 

10 searching a database to locate a record of said identifier; 

and 

comparing a stored fingerprint provided in association with 
said identifier with the received user's fingerprint data, whereby if the 
stored fingerprint docs not match the received user's fingerprint data, 
15 blocking installation of tlic software program. 

13. A computer readable medium as recited in claim 11, further 
comprising the following instructions; 

receiving an identifier of a copy of the software program 

20 to be installed; 

searching a database to locate a record of said identifier; 

and 

determining whetlier the number of installations of the 
software program exceeds a pre-set maximum, whereby if tlie number 
25 of installations exceeds the pre-set maximum, blocking installation of 

m 

the software program, 

14. A computer readable medium as recited in claim 11, wherein 
the instruction for receiving a user's fingerprint data comprises 

30 receiving a transmission of tiie user's fingerprint data from a remote 
location. 

15. A method for controlling use of a softwaix program, the 

method comprising: 
35 accepting fingerprint data from a user of the software 

program; 

comparing the user's fingerprint data with stored 
fingerprint data provided for the software program; and 
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10 



if ihc user's fingerprint data does not match the stored 
fingerprint data, blocking execution of the software program. 

16. The method of claim 15, furdier comprising: 

beginning execution of the software program; and 
prompting the user to provide said fingerprint data prior to 
continued execution of tlie software program. 

17. The mediod of claim 15, wherein the stored fingerprint data 
was obtained from a purchaser of the software program 
contemporaneous with a purchase of the software program. 



18. The method of claim 15, wiierein the stored fingerprint data 
contains fingerprint data for a plurality of users of the software 

15 program. 

19. A computer readable medium including instructions for 
operating a computer system such that it controls use of a software 
program, the instructions comprising: 

20 accepting fingerprint data from a user of the software 

program; 

comparing die user's fingerprint data with stored 
fingerprint data provided for the software program; and 

if the user's fingerprint data does not match the stored 
25 fingerprint data, blocking execution of the software program. 

20. A computer readable medium as recited in claim 19, further 
comprising the following instructions: 

beginning execution of the software program; and 
30 prompting the user to provide said fingerprint data prior to 

continued execution of the software program. 

21. A computer readable medium as recited in claim 19, wherein 
the stored fingerprint data was obtained from a purchaser of tiie 

35 software program contemporaneous with a purchase of the software 
program. 
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22. A computer readable medium as recited in claim 19, wherein 
the stored ftngerprint data contains fingerprint data for a plurality of 
users of the software program. 

5 23. A method for controlling use of a software program, the 

method comprising: 

accepting fingerprint data from a user of the software 

program; 

determining whether the user's fingerprint data allows 

10 access to die software program; and 

if the user's fingerprint data is found to allow access to the 
software program, monitoring a quantity of use of said software by said 
user so that the user can be charged for the quantity of use. 

15 24. The method of claim 23, a lengtli of time during which die 

software program is operated comprises the quantity of use. 
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